<html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><meta http-equiv="Content-Language" content="zh-CN"><title>environment.d
  中文手册 [金步国]</title><style>
@font-face { font-family: "JinBuGuoWebMono"; src: url("http://www.jinbuguo.com/d/mono.ttf") format("truetype"); }
* { font-family: "JinBuGuoWebMono", "Ubuntu Mono", "Consolas", "Menlo", monospace; }
body { margin:10px; }
h1 { text-align:center; background:#ddd; }
h2#auth_name { text-align:center; margin: 10px 5%; }

    a.headerlink {
      color: #c60f0f;
      font-size: 0.8em;
      padding: 0 4px 0 4px;
      text-decoration: none;
      visibility: hidden;
    }

    a.headerlink:hover {
      background-color: #c60f0f;
      color: white;
    }

    h1:hover > a.headerlink, h2:hover > a.headerlink, h3:hover > a.headerlink, dt:hover > a.headerlink {
      visibility: visible;
    }
</style><script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><h1>environment.d 中文手册</h1><h2 id="auth_name">译者：<strong><a href="http://www.jinbuguo.com/">金步国</a></strong></h2><hr><h3>版权声明</h3><p>本文译者是一位开源理念的坚定支持者，所以本文虽然不是软件，但是遵照开源的精神发布。</p><ul><li>无担保：本文译者不保证译文内容准确无误，亦不承担任何由于使用此文档所导致的损失。</li><li>自由使用：任何人都可以自由的<u>阅读/链接/打印</u>此文档，无需任何附加条件。</li><li>名誉权：任何人都可以自由的<u>转载/引用/再创作</u>此文档，但必须保留译者署名并注明出处。</li></ul><h3>其他作品</h3><p>本文译者十分愿意与他人分享劳动成果，如果你对我的其他翻译作品或者技术文章有兴趣，可以在如下位置查看现有的作品集：</p><ul><li><a href="http://www.jinbuguo.com/">金步国作品集</a> [ <a href="http://www.jinbuguo.com/">http://www.jinbuguo.com/</a> ]</li></ul><h3>联系方式</h3><p>由于译者水平有限，因此不能保证译文内容准确无误。如果你发现了译文中的错误(哪怕是错别字也好)，请来信指出，任何提高译文质量的建议我都将虚心接纳。</p><ul><li>Email(QQ)：70171448在QQ邮箱</li></ul><hr><a href="systemd.index.html">手册索引</a> ·
  <a href="systemd.directives.html">指令索引</a><span style="float:right">systemd-241</span><hr><div class="refentry"><a name="environment.d"></a><div class="titlepage"></div><div class="refnamediv"><h2>名称</h2><p>environment.d — 定义 systemd 用户实例的运行环境</p></div><div class="refsynopsisdiv"><h2>大纲</h2><p><code class="filename">~/.config/environment.d/*.conf</code></p><p><code class="filename">/etc/environment.d/*.conf</code></p><p><code class="filename">/run/environment.d/*.conf</code></p><p><code class="filename">/usr/lib/environment.d/*.conf</code></p><p><code class="filename">/etc/environment</code></p></div><div class="refsect1"><a name="id-1.5"></a><h2 id="描述">描述<a class="headerlink" title="Permalink to this headline" href="environment.d.html#%E6%8F%8F%E8%BF%B0">¶</a></h2><p> <code class="filename">environment.d</code> 目录中包含了一系列
    用于设置用户运行环境的"全局"环境变量。
    <a href="systemd-environment-d-generator.html#"><span class="citerefentry"><span class="refentrytitle">systemd-environment-d-generator</span>(8)</span></a>
    将会使用这些变量来更新 systemd 用户实例(--user)所启动的服务的
    运行环境。</p><p>为了简化配置文件的排序，建议在所有配置文件的名字中都使用两位数字的前缀。</p><p>出于向后兼容的原因，将会默认安装一个指向 <code class="filename">/etc/environment</code> 的软连接，
    以确保包含该文件的内容。</p></div><div class="refsection"><a name="confd"></a><h2>配置目录及其优先级</h2><p>配置文件依次从
    <code class="filename">/etc/</code>, <code class="filename">/run/</code>, <code class="filename">/usr/lib/</code>
    目录中读取。
    配置文件的名称必须符合 <code class="filename"><em class="replaceable"><code>filename</code></em>.conf</code> 格式。
    对于不同目录下的同名配置文件，仅以优先级最高的目录中的那一个为准。
    具体说来就是：
    <code class="filename">/etc/</code> 的优先级最高、
    <code class="filename">/run/</code> 的优先级居中、
    <code class="filename">/usr/lib/</code> 的优先级最低。</p><p>软件包应该将自带的配置文件安装在 
    <code class="filename">/usr/lib/</code> 目录中。
    <code class="filename">/etc/</code> 目录仅供系统管理员使用。
    所有的配置文件(无论位于哪个目录中)，
    统一按照文件名的字典顺序处理。
    如果在多个配置文件中设置了同一个选项，
    那么仅以文件名最靠后(字典顺序)的那一个为准。
    为了便于排序，建议给所有配置文件
    都加上两位十进制数字的文件名前缀。</p><p>如果系统管理员想要屏蔽 <code class="filename">/usr/lib/</code> 目录中的某个配置文件，
    那么最佳做法是在 <code class="filename">/etc/</code> 目录中
    创建一个指向 <code class="filename">/dev/null</code> 的同名符号链接，
    即可彻底屏蔽 <code class="filename">/usr/lib/</code> 目录中的同名文件。
    如果软件包自带的某个配置文件位于 initrd 镜像中，
    那么还必须重新生成 initrd 镜像。</p></div><div class="refsect1"><a name="id-1.7"></a><h2 id="配置文件格式">配置文件格式<a class="headerlink" title="Permalink to this headline" href="environment.d.html#%E9%85%8D%E7%BD%AE%E6%96%87%E4%BB%B6%E6%A0%BC%E5%BC%8F">¶</a></h2><p>配置文件包含一系列由换行符分隔的
    "<code class="literal"><em class="replaceable"><code>KEY</code></em>=<em class="replaceable"><code>VALUE</code></em></code>"
    行。可以在等号右侧使用
     "<code class="literal">${OTHER_KEY}</code>"
    或 "<code class="literal">$OTHER_KEY</code>" 格式直接引用先前已经定义过的环境变量；也可以在等号右侧使用

    "<code class="literal">${<em class="replaceable"><code>FOO</code></em>:-<em class="replaceable"><code>DEFAULT_VALUE</code></em>}</code>"
    格式表示如果环境变量 <em class="replaceable"><code>FOO</code></em> 的值为空，那么展开为 <em class="replaceable"><code>DEFAULT_VALUE</code></em> (相当于默认值)，
    否则严格按照 "<code class="literal">${<em class="replaceable"><code>FOO</code></em>}</code>" 的方式按原值展开；
    还可以在等号右侧使用
    "<code class="literal">${<em class="replaceable"><code>FOO</code></em>:+<em class="replaceable"><code>ALTERNATE_VALUE</code></em>}</code>"
    格式表示如果环境变量 <em class="replaceable"><code>FOO</code></em> 的值为非空，那么展开为 <em class="replaceable"><code>ALTERNATE_VALUE</code></em> (相当于强制替换为另一个值)，
    否则严格按照 "<code class="literal">${<em class="replaceable"><code>FOO</code></em>}</code>" 的方式展开为空值。
    除此之外，不再支持任何其他的 shell 语法。</p><p>每一个 <em class="replaceable"><code>KEY</code></em> 都必须是一个合格的变量名(符合变量命名规则)。
    空行或者以 "<code class="literal">#</code>" 开头的行都将被忽略。</p><div class="refsect2"><a name="id-1.7.4"></a><h3 id="例子">例子<a class="headerlink" title="Permalink to this headline" href="environment.d.html#%E4%BE%8B%E5%AD%90">¶</a></h3><div class="example"><a name="id-1.7.4.2"></a><p class="title"><b>例 1. 设置环境变量以允许访问安装在
        <code class="filename">/opt/foo</code> 目录中的程序</b></p><div class="example-contents"><p><code class="filename">/etc/environment.d/60-foo.conf</code>:
        </p><pre class="programlisting">
        FOO_DEBUG=force-software-gl,log-verbose
        PATH=/opt/foo/bin:$PATH
        LD_LIBRARY_PATH=/opt/foo/lib${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}
        XDG_DATA_DIRS=/opt/foo/share:${XDG_DATA_DIRS:-/usr/local/share/:/usr/share/}
        </pre></div></div><br class="example-break"></div></div><div class="refsect1"><a name="id-1.8"></a><h2 id="参见">参见<a class="headerlink" title="Permalink to this headline" href="environment.d.html#%E5%8F%82%E8%A7%81">¶</a></h2><p>
      <a href="systemd.html#"><span class="citerefentry"><span class="refentrytitle">systemd</span>(1)</span></a>,
      <a href="systemd-environment-d-generator.html#"><span class="citerefentry"><span class="refentrytitle">systemd-environment-d-generator</span>(8)</span></a>,
      <a href="systemd.environment-generator.html#"><span class="citerefentry"><span class="refentrytitle">systemd.environment-generator</span>(7)</span></a>
    </p></div></div></body></html>
